Astro-float (astronomically large floating-point numbers) is an arbitrary precision floating-point numbers library designed for performance, portability, and implemented purely in Rust.
The library implements the basic operations and functions. It uses classical algorithms such as Karatsuba, Toom-Cook, Schönhage-Strassen algorithm, and others.
The library can work without the standard library provided there is a memory allocator.
What's new
Information about the latest changes is available in Release notes
Usage
Below is an example of using the library. For more information please refer to the library documentation: https://docs.rs/astro-float/latest/astro_float/
Calculate Pi with 1024 bit precision rounded to the nearest even number.
use Consts;
use RoundingMode;
use Context;
use expr;
// Create a context with precision 1024, and rounding to even.
let mut ctx = new;
// Compute pi: pi = 6*arctan(1/sqrt(3))
let pi = expr!;
// Use library's constant value for verifying the result.
let pi_lib = ctx.const_pi;
// Compare computed constant with library's constant
assert_eq!;
Performance
Benchmark can be found here: https://github.com/stencillogic/bigfloat-bench.
Contributing
Issues regarding bugs or new features can be opened here: https://github.com/stencillogic/astro-float/issues
For more information please check CONTRIBUTING.md